草庐IT

c++ - 异常安全和 make_unique

全部标签

ruby - 断言 Cucumber 中抛出了一个特定的异常

场景我正在编写一个库(没有RubyonRails),我想为其提供非常详细的Cucumber功能。这尤其包括描述在各种情况下应该抛出的错误/异常。示例编写Cucumber步骤最直观的方式可能是这样的WhenIdosomethingunwantedThenan"ArgumentError"shouldbethrown问题我必须解决两个问题:抛出异常时,第一步不应失败。第一步抛出的异常应该可供第二步访问,以便执行一些断言魔法。不优雅和繁琐的解决方案我能想到的最佳方法是在第一步中缓存异常并将其放入第二步可以访问的实例变量中,如下所示:When/^Idosomethingunwanted$/do

c - 如何在 Mac OS X 上使用 ulimit 或每个进程为 C 或 Ruby 程序更改堆栈大小?

似乎为C程序或Ruby程序(使用C堆栈)设置堆栈大小的推荐方法是使用ulimit。在Bash外壳中。但是$ulimit-s8192$ulimit-s16384-bash:ulimit:stacksize:cannotmodifylimit:Operationnotpermitted和sudo也没有帮助。有没有办法将其设置为16MB、32MB或64MB?我认为应该有一种方法可以在每次程序调用时设置它,而不是同时设置系统范围的参数?现在8192可能意味着8MB,如果与一个进程可以使用的内存量相比,这是非常小的,有时最多2GB的RAM。(更新注释:ulimit-a可以显示其当前值)。(更新2

ruby - 使用 Hash#dig 或 Lonely operator(&.) 安全地为嵌套哈希赋值

h={data:{user:{value:"JohnDoe"}}}要为嵌套哈希赋值,我们可以使用h[:data][:user][:value]="Bob"但是如果中间的任何部分缺失,就会导致错误。有点像h.dig(:data,:user,:value)="Bob"不会工作,因为还没有可用的Hash#dig=。要安全地赋值,我们可以做h.dig(:data,:user)&.[]=(:value,"Bob")#orequivalentlyh.dig(:data,:user)&.store(:value,"Bob")但是有更好的方法吗? 最佳答案

ruby - Regexp.last_match 线程安全吗?

这是我正在查看的代码:defmethod_missing(id,*args)returnself.find(Regexp.last_match(1),args[0])ifid.id2name=~/find_by_(.+)/raiseNoMethodErrorend如果我有多个线程调用Regexp.last_match会怎样?如果我有多个线程使用method_missing方法调用对象会怎样? 最佳答案 Ruby1.9.2平台文档声明调用Regexp.last_match等同于读取特殊的$~全局变量。摘自“TheRubyProgram

ruby - 在 Ruby 中将 [] 与安全导航运算符一起使用

我目前有一段代码如下:ifmatch=request.path.match(/\A\/(?(?!admin|assets)\w+)/)match[:slug]end有没有办法使用安全导航运算符(在2.3.0中引入)来避免这种if条件? 最佳答案 只需使用普通(无糖)形式即可。request.path.match(/\A\/(?(?!admin|assets)\w+)/)&.[](:slug) 关于ruby-在Ruby中将[]与安全导航运算符一起使用,我们在StackOverflow上找到

ruby-on-rails - Ruby/Rails 线程安全

我时常研究Ruby,但我没有用它做过任何大的或多线程的事情。我听说MRI只支持绿色线程,而JRuby通过JVM支持native线程。然而,我偶然发现博客和讨论组上的评论说“Rails不是线程安全的”或者Ruby本身不是线程安全的。例如有人评论说require语句有问题。这听起来有点基础。我见过很多不能正确处理并发的Java应用程序,我时不时地做噩梦:-)但至少你可以用Java编写线程安全的应用程序如果您真的知道自己在做什么(这并不容易)。这一切听起来很令人震惊,有人可以详细说明一下吗?到底是什么问题,如果是这种情况,Rails是如何设法工作的?我可以编写在没有竞争条件和死锁的情况下正常

ruby-on-rails - RSpec 重试抛出异常然后返回值

我有一个重试blockdefmy_methodapp_instances=[]attempts=0beginapp_instances=fetch_and_rescan_app_instances(page_n,policy_id,policy_cpath)rescueExceptionattempts+=1retryunlessattempts>2raiseExceptionendpage_n+=1end其中fetch_and_rescan_app_instances访问网络,因此可以抛出异常。我想编写一个rspec测试,它第一次抛出异常,第二次调用时不抛出异常,所以我可以测试它是否

ruby-on-rails - 在某些 RSpec rails 请求示例中测试 HTTP 状态代码,但在其他示例中测试引发的异常

在使用rspec-rails测试的Rails4.2.0应用程序中,我提供了一个JSONWebAPI,它带有一个类似REST的资源,带有强制属性mand_attr.当POST请求中缺少该属性时,我想测试此API是否使用HTTP代码400(BADREQUEST)进行响应。(参见下图第二个示例。)我的Controller尝试通过抛出ActionController::ParameterMissing来引发此HTTP代码,如下面的第一个RSpec示例所示。在otherRSpec示例中,我希望引发的异常被示例拯救(如果它们是预期的)或击中测试运行器,所以它们显示给开发人员(如果错误是意外的),因

ruby - 如何处理不知道 Ruby 中的库方法可以引发哪些异常?

这是一个比较宽泛的问题,但这是我在使用Ruby编程时不断遇到的问题。我主要来自C和Java背景,当我使用库函数或方法时,我会查看文档并查看它在错误时返回什么(通常在C中)或它可以抛出哪些异常(在Java中)。在Ruby中,情况似乎完全不同。刚才我需要解析从服务器接收到的一些JSON:data=JSON.parse(response)写完这段代码我首先想到的自然是,如果输入不好怎么办?parse是否会在出错时返回nil,或者引发一些异常,如果是,是哪些异常?我检查了文档(http://flori.github.com/json/doc/JSON.html#M000022)并简单地看到:“

ruby-on-rails - Ruby 中的 `try` 和 `&.`(安全导航运算符)有什么区别

这是我的代码:classOrder我以为&.是.try的快捷方式,但我想我错了。有人可以指出我所缺少的正确方向吗?感觉跟ruby无关。也许是葡萄?虽然我不明白这是怎么回事。 最佳答案 &.的工作方式类似于#try!,而不是#try。这里是#try!的描述(来自documentation):Sameas#try,butwillraiseaNoMethodErrorexceptionifthereceivingisnotnilanddoesnotimplementedthetriedmethod.所以基本上它可以避免在nil上调用方法,